from(X) → cons(X, from(s(X)))
head(cons(X, XS)) → X
2nd(cons(X, XS)) → head(XS)
take(0, XS) → nil
take(s(N), cons(X, XS)) → cons(X, take(N, XS))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, XS)
↳ QTRS
↳ Overlay + Local Confluence
from(X) → cons(X, from(s(X)))
head(cons(X, XS)) → X
2nd(cons(X, XS)) → head(XS)
take(0, XS) → nil
take(s(N), cons(X, XS)) → cons(X, take(N, XS))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, XS)
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
from(X) → cons(X, from(s(X)))
head(cons(X, XS)) → X
2nd(cons(X, XS)) → head(XS)
take(0, XS) → nil
take(s(N), cons(X, XS)) → cons(X, take(N, XS))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, XS)
from(x0)
head(cons(x0, x1))
2nd(cons(x0, x1))
take(0, x0)
take(s(x0), cons(x1, x2))
sel(0, cons(x0, x1))
sel(s(x0), cons(x1, x2))
SEL(s(N), cons(X, XS)) → SEL(N, XS)
TAKE(s(N), cons(X, XS)) → TAKE(N, XS)
2ND(cons(X, XS)) → HEAD(XS)
FROM(X) → FROM(s(X))
from(X) → cons(X, from(s(X)))
head(cons(X, XS)) → X
2nd(cons(X, XS)) → head(XS)
take(0, XS) → nil
take(s(N), cons(X, XS)) → cons(X, take(N, XS))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, XS)
from(x0)
head(cons(x0, x1))
2nd(cons(x0, x1))
take(0, x0)
take(s(x0), cons(x1, x2))
sel(0, cons(x0, x1))
sel(s(x0), cons(x1, x2))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ EdgeDeletionProof
SEL(s(N), cons(X, XS)) → SEL(N, XS)
TAKE(s(N), cons(X, XS)) → TAKE(N, XS)
2ND(cons(X, XS)) → HEAD(XS)
FROM(X) → FROM(s(X))
from(X) → cons(X, from(s(X)))
head(cons(X, XS)) → X
2nd(cons(X, XS)) → head(XS)
take(0, XS) → nil
take(s(N), cons(X, XS)) → cons(X, take(N, XS))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, XS)
from(x0)
head(cons(x0, x1))
2nd(cons(x0, x1))
take(0, x0)
take(s(x0), cons(x1, x2))
sel(0, cons(x0, x1))
sel(s(x0), cons(x1, x2))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ EdgeDeletionProof
↳ QDP
↳ DependencyGraphProof
2ND(cons(X, XS)) → HEAD(XS)
TAKE(s(N), cons(X, XS)) → TAKE(N, XS)
SEL(s(N), cons(X, XS)) → SEL(N, XS)
FROM(X) → FROM(s(X))
from(X) → cons(X, from(s(X)))
head(cons(X, XS)) → X
2nd(cons(X, XS)) → head(XS)
take(0, XS) → nil
take(s(N), cons(X, XS)) → cons(X, take(N, XS))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, XS)
from(x0)
head(cons(x0, x1))
2nd(cons(x0, x1))
take(0, x0)
take(s(x0), cons(x1, x2))
sel(0, cons(x0, x1))
sel(s(x0), cons(x1, x2))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ EdgeDeletionProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ QDP
SEL(s(N), cons(X, XS)) → SEL(N, XS)
from(X) → cons(X, from(s(X)))
head(cons(X, XS)) → X
2nd(cons(X, XS)) → head(XS)
take(0, XS) → nil
take(s(N), cons(X, XS)) → cons(X, take(N, XS))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, XS)
from(x0)
head(cons(x0, x1))
2nd(cons(x0, x1))
take(0, x0)
take(s(x0), cons(x1, x2))
sel(0, cons(x0, x1))
sel(s(x0), cons(x1, x2))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
SEL(s(N), cons(X, XS)) → SEL(N, XS)
s1 > SEL1
SEL1: multiset
s1: multiset
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ EdgeDeletionProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
↳ QDP
↳ QDP
from(X) → cons(X, from(s(X)))
head(cons(X, XS)) → X
2nd(cons(X, XS)) → head(XS)
take(0, XS) → nil
take(s(N), cons(X, XS)) → cons(X, take(N, XS))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, XS)
from(x0)
head(cons(x0, x1))
2nd(cons(x0, x1))
take(0, x0)
take(s(x0), cons(x1, x2))
sel(0, cons(x0, x1))
sel(s(x0), cons(x1, x2))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ EdgeDeletionProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
TAKE(s(N), cons(X, XS)) → TAKE(N, XS)
from(X) → cons(X, from(s(X)))
head(cons(X, XS)) → X
2nd(cons(X, XS)) → head(XS)
take(0, XS) → nil
take(s(N), cons(X, XS)) → cons(X, take(N, XS))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, XS)
from(x0)
head(cons(x0, x1))
2nd(cons(x0, x1))
take(0, x0)
take(s(x0), cons(x1, x2))
sel(0, cons(x0, x1))
sel(s(x0), cons(x1, x2))
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
TAKE(s(N), cons(X, XS)) → TAKE(N, XS)
s1 > TAKE1
TAKE1: multiset
s1: multiset
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ EdgeDeletionProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDPOrderProof
↳ QDP
↳ PisEmptyProof
↳ QDP
from(X) → cons(X, from(s(X)))
head(cons(X, XS)) → X
2nd(cons(X, XS)) → head(XS)
take(0, XS) → nil
take(s(N), cons(X, XS)) → cons(X, take(N, XS))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, XS)
from(x0)
head(cons(x0, x1))
2nd(cons(x0, x1))
take(0, x0)
take(s(x0), cons(x1, x2))
sel(0, cons(x0, x1))
sel(s(x0), cons(x1, x2))
↳ QTRS
↳ Overlay + Local Confluence
↳ QTRS
↳ DependencyPairsProof
↳ QDP
↳ EdgeDeletionProof
↳ QDP
↳ DependencyGraphProof
↳ AND
↳ QDP
↳ QDP
↳ QDP
FROM(X) → FROM(s(X))
from(X) → cons(X, from(s(X)))
head(cons(X, XS)) → X
2nd(cons(X, XS)) → head(XS)
take(0, XS) → nil
take(s(N), cons(X, XS)) → cons(X, take(N, XS))
sel(0, cons(X, XS)) → X
sel(s(N), cons(X, XS)) → sel(N, XS)
from(x0)
head(cons(x0, x1))
2nd(cons(x0, x1))
take(0, x0)
take(s(x0), cons(x1, x2))
sel(0, cons(x0, x1))
sel(s(x0), cons(x1, x2))